草庐IT

c++ - std::pair 引用

全部标签

go - GCC 未定义的构建引用

我正在尝试使用golang为windowsamd64构建一个exe。除了“gorun”或“gobuild”之外,一切都运行顺利。构建过程中断了来自github.com/andlabs/ui的包的gcc编译。跟踪如下:$gobuild#gitlab.com/asnossascenas/dbRegistration/uiC:\Users\Pat\AppData\Local\Temp\go-build167765418\gitlab.com\asnossascenas\dbRegistration\ui\_obj\table.cgo2.o:Infunction`_cgo_1e2a701ee8

c - 如何将返回的 uint8_u 转换为 ARM 中的 GoString?

我使用cgo从Go调用C函数。该函数的返回类型为uint8_u*。我知道它是一个字符串,需要在Go中打印它。我在myFile.go中有以下内容packagemain//#cgoCFLAGS:-g//#include//#include"cLogic.h"import"C"import("fmt""unsafe")funcmain(){myString:="DUMMY"cMyString:=C.CString(myString)deferC.free(unsafe.Pointer(cMyString))cMyInt:=C.int(10)cResult:=C.MyCFunction(cMy

c - 使用 cgo 构建共享对象时导出变量

我想使用带有选项gobuild-buildmode=c-shared的Go/Cgo构建一个.so库。函数导出良好,但我无法导出变量。我需要实现一个API,它通过调用一个void函数来工作,该函数设置各种全局属性的值。像这样:var(Gval1intGval2string//GvalN)funcf(){Gval1=1Gval2="qwerty"}.solib的客户端将运行f();之后,它可以通过寻址变量的名称来获取变量。我怎样才能导出它们?我曾尝试过这样的把戏:golangcgocan'texportvariablesbybuildmodec-shared,但没有成功(示例始终返回0,而

go - 无效的内存地址或 nil 指针与 mgo 取消引用

packagemainimport("encoding/json""fmt""io/ioutil""net/http""github.com/gorilla/handlers""github.com/gorilla/mux""gopkg.in/mgo.v2")typeDataIgstruct{Memberstring`json:"Member"`Timestampfloat64`json:"Timestamp"`Namestring`json:"Name"`Bidstring`json:"Bid"`Offerstring`json:"Offer"`Changestring`json:"

go - 如何将不遵守主要子文件夹约定的 Go 包的 v2.0.0 作为模块引用

我们正在运行一个spike来确定我们如何或者是否可以将我们的堆栈迁移到Go模块。我们依赖v2.0.0https://github.com/gbrlsnchs/jwt但它既没有转换为模块本身,也没有遵守将主要版本放在子文件夹下的Go约定。在将我们的内部包转换为具有这种依赖性的模块时,我们有哪些选择? 最佳答案 github.com/gbrlsnchs/jwt在v2.0.0有一个go.mod文件表明它的规范导入路径是github.com/gbrlsnchs/jwt/v2.更新你的import语句以使用该路径——它也应该在Go1.9.7、

pointers - 如何以并行方式传递指针的引用?

我正在编写一个机器人来并行运行一些命令并同时并行运行机器人,但我在启动和暂停功能时遇到了问题。下面我将留下一个我设置的例子。预计其中一个bot会继续运行而其他bot会停止,但所有bot最终都会运行。有人可以向我解释为什么在使用startbot()命令时,它没有得到bool值吗?packagemainimport("log""time")typebotBasestruct{isEnabledbool}func(b*botBase)startFunctionX(){b.isEnabled=true}func(b*botBase)pauseFunctionX(){b.isEnabled=fa

go - 在 Go 中按值传递还是按引用传递效率更高?

假设我有一个实现如下接口(interface)的结构:typeIFaceinterface{Method1()Method2()Method3()}typeFacestruct{Prop1stringProp2int}//IFaceimplementationhere...现在,如果我有接受IFace的方法,将其设计为接受指向该值接口(interface)的指针是否更好?接受指针:funcDummyMethod(f*IFace){(*f).Method1()}按值:funcDummyMethod(fIFace){f.Method1()}我的第一个猜测是因为这些是结构体,所以按值传递可能

c - 有没有办法在调用 MakeWS2811() 后修改 rpi-ws281x-go 库中 LED 的亮度?

我一直在使用RaspberryPi和Golang来制作一些WS2812LED的动画。我一直在使用rpi-ws281x-go(https://github.com/rpi-ws281x/rpi-ws281x-go)库,它是一个围绕C库(https://github.com/jgarff/rpi_ws281x)的Go包装器。我对C不是很熟悉,更不用说C库的Go包装器了。我可以看到在C代码中,我可以访问和更改每次调用渲染函数时应用的LED的亮度。但是,在Go包装器库中,我看不到访问该变量的方法。我可以看到,当我调用ws2811.MakeWS2811(&opt)时,我可以在opt结构中设置亮度

go - grpc:使用 oneof 会导致无效的内存地址或 nil 指针取消引用

我正在尝试使用Go将proto3结构发送到gRPC服务器。该结构有一个oneof类型,我似乎很好地填充了它。将消息发送到我的gRPC客户端时,我对无效内存地址或nil指针引用感到panic。我有原型(prototype)定义(完整文件位于https://github.com/MovingGauteng/geofancy-rs/blob/master/proto/geofancy.proto:#proto3messageDocument{stringcollection=1;stringid=2;oneofgeo{Pointpoint=4;LineStringline=5;Boundsb

go - 对结构中字段的外部引用是否会阻止该结构被垃圾收集?

例如,如果我有一些typeAstruct{Bstring;Cint},我有一个funcfoo(aA)*string{return&a.B},我用c:=foo(a),a是否必须保留在上下文中,直到c可收集?或者,如果我定义funcfoo1(aA)*string{s:=a.B;return&s这对何时可以收集A有什么影响吗? 最佳答案 在第一个例子中,假设a在调用foo(a)之后没有被使用,a是可收集的,因为你通过了a按值。该函数返回一个指向a副本中的值的指针,因此a变得可收集,但在函数foo中创建的副本不可收集收藏品。现在,如果您将&